<template>
	<view class="themeItem">
		<view v-for="item in projectStore.projectList" :key="item.id" @click="toProject(item.id)" class="box" v-if="!isMore">
			<image class="pic" :src="item.src[0]" mode="aspectFill"></image>
			<view class="mask">{{item.name}}</view>
			<view class="tab">{{item.time}}</view>
		</view>

		<view @click="openMore" class="box more">
			<image class="pic" src="../../common/images/more.jpg" mode="aspectFill"></image>
			<view class="mask">
				<uni-icons type="more-filled" size="34" color="#fff"></uni-icons>
				<view class="text">更多</view>
			</view>
		</view>
		<uni-popup ref="alertDialog" type="dialog">
			<uni-popup-dialog  cancelText="关闭" confirmText="同意" title="更多" content="更多项目示例，敬请期待，更希望能参与贵公司项目实例！！"
				@confirm="dialogConfirm" @close="dialogClose"></uni-popup-dialog>
		</uni-popup>
	</view>
</template>

<script setup>
	import {ref} from 'vue';
	import {useProjectStore} from '@/stores/projectPreview.js'
	defineProps({
		isMore: {
			type: Boolean,
			default: false
		}
	})
	
	const projectStore = useProjectStore();
	
	let alertDialog=ref()
	function openMore(){
		alertDialog.value.open()
	}
	function toProject(id){
		uni.navigateTo({
		url:`/pages/preview/preview?id=${id}`
		})

	}
</script>

<style lang="scss" scoped>
	.themeItem {
		margin-top: 30rpx;
		padding: 0 30rpx;
		display: grid;
		gap: 15rpx;
		grid-template-columns: repeat(3, 1fr);

		.box {
			height: 340rpx;
			border-radius: 10rpx;
			overflow: hidden;
			position: relative;

			.pic {
				width: 100%;
				height: 100%;
			}

			.mask {
				width: 100%;
				height: 70rpx;
				position: absolute;
				bottom: 0;
				left: 0;
				background: rgba(0, 0, 0, 0.2);
				color: #fff;
				display: flex;
				align-items: center;
				justify-content: center;
				backdrop-filter: blur(20rpx);
				font-weight: 600;
				font-size: 30rpx;
			}

			.tab {
				position: absolute;
				left: 0;
				top: 0;
				background: rgba(250, 129, 90, 0.7);
				backdrop-filter: blur(20rpx);
				color: #fff;
				font-size: 22rpx;
				padding: 6rpx 14rpx;
				border-radius: 0 0 20rpx 0;
				transform: scale(0.8);
				transform-origin: left top;
			}
		}

		.box.more {
			.mask {
				width: 100%;
				height: 100%;
				flex-direction: column;
			}

			.text {
				font-size: 28rpx;
			}
		}
	}
</style>